//
//    agast7d - AGAST, an adaptive and generic corner detector based on the
//              accelerated segment test for a 12 pixel mask in diamond format
//
//    Copyright (C) 2010  Elmar Mair
//
//    This program is free software: you can redistribute it and/or modify
//    it under the terms of the GNU General Public License as published by
//    the Free Software Foundation, either version 3 of the License, or
//    (at your option) any later version.
//
//    This program is distributed in the hope that it will be useful,
//    but WITHOUT ANY WARRANTY; without even the implied warranty of
//    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
//    GNU General Public License for more details.
//
//    You should have received a copy of the GNU General Public License
//    along with this program.  If not, see <http://www.gnu.org/licenses/>.

//machine generated code
//probability of an equal pixel on the Bresenham's circle: 0.33 and 0.1
//number of equal pixels to switch: 2
//number of unequal pixels to switch: 9
//memory costs: cache=0.2
//              same line=1
//              memory=4

#include <stdint.h>																			
#include <stdlib.h>
#include <agast/cvWrapper.h>
#include <agast/agast7_12d.h>

using namespace std;
using namespace agast;

void AgastDetector7_12d::detect(const unsigned char* im, vector<CvPoint>& corners_all, const cv::Mat* thrmap)
{
	int total=0;
	int nExpectedCorners=corners_all.capacity();
	CvPoint h;
	register int x, y;
	register int xsizeB=xsize - 4;
	register int ysizeB=ysize - 3;
	register int_fast16_t offset0, offset1, offset2, offset3, offset4, offset5, offset6, offset7, offset8, offset9, offset10, offset11;
	register int width;

	corners_all.resize(0);

	offset0=s_offset0;
	offset1=s_offset1;
	offset2=s_offset2;
	offset3=s_offset3;
	offset4=s_offset4;
	offset5=s_offset5;
	offset6=s_offset6;
	offset7=s_offset7;
	offset8=s_offset8;
	offset9=s_offset9;
	offset10=s_offset10;
	offset11=s_offset11;
	width=xsize;

	for(y=3; y < ysizeB; y++)
	{										
		x=2;
		while(1)							
		{									
homogeneous:
{
			x++;			
			if(x>xsizeB)	
				break;		
			else
			{
				register const unsigned char* const p = im + y*width + x;
				register const int cb = *p + b;
				register const int c_b = *p - b;
				if(p[offset0] > cb)
				  if(p[offset5] > cb)
					if(p[offset2] > cb)
					  if(p[offset9] > cb)
						if(p[offset1] > cb)
						  if(p[offset6] > cb)
							if(p[offset3] > cb)
							  if(p[offset4] > cb)
								goto success_homogeneous;
							  else
								if(p[offset10] > cb)
								  if(p[offset11] > cb)
									goto success_structured;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  if(p[offset11] > cb)
									goto success_structured;
								  else
									if(p[offset4] > cb)
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset11] > cb)
							  if(p[offset3] > cb)
								if(p[offset4] > cb)
								  goto success_homogeneous;
								else
								  if(p[offset10] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset8] > cb)
								  if(p[offset10] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  goto homogeneous;
						else
						  if(p[offset6] > cb)
							if(p[offset7] > cb)
							  if(p[offset8] > cb)
								if(p[offset4] > cb)
								  if(p[offset3] > cb)
									goto success_structured;
								  else
									if(p[offset10] > cb)
									  goto success_structured;
									else
									  goto homogeneous;
								else
								  if(p[offset10] > cb)
									if(p[offset11] > cb)
									  goto success_structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
					  else
						if(p[offset3] > cb)
						  if(p[offset4] > cb)
							if(p[offset1] > cb)
							  if(p[offset6] > cb)
								goto success_homogeneous;
							  else
								if(p[offset11] > cb)
								  goto success_homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset6] > cb)
								if(p[offset7] > cb)
								  if(p[offset8] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					else
					  if(p[offset9] > cb)
						if(p[offset7] > cb)
						  if(p[offset8] > cb)
							if(p[offset1] > cb)
							  if(p[offset10] > cb)
								if(p[offset11] > cb)
								  goto success_homogeneous;
								else
								  if(p[offset6] > cb)
									if(p[offset4] > cb)
									  goto success_structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset6] > cb)
								  if(p[offset3] > cb)
									if(p[offset4] > cb)
									  goto success_structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset6] > cb)
								if(p[offset4] > cb)
								  if(p[offset3] > cb)
									goto success_homogeneous;
								  else
									if(p[offset10] > cb)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset10] > cb)
									if(p[offset11] > cb)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					  else
						goto homogeneous;
				  else
					if(p[offset5] < c_b)
					  if(p[offset9] > cb)
						if(p[offset3] < c_b)
						  if(p[offset4] < c_b)
							if(p[offset11] > cb)
							  if(p[offset1] > cb)
								if(p[offset8] > cb)
								  if(p[offset10] > cb)
									if(p[offset2] > cb)
									  goto success_structured;
									else
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
								  else
									goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset2] < c_b)
									  if(p[offset7] < c_b)
										if(p[offset8] < c_b)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset6] > cb)
								  if(p[offset7] > cb)
									if(p[offset8] > cb)
									  if(p[offset10] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset2] < c_b)
									  if(p[offset7] < c_b)
										if(p[offset1] < c_b)
										  goto success_structured;
										else
										  if(p[offset8] < c_b)
											goto success_structured;
										  else
											goto structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							else
							  if(p[offset2] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset1] < c_b)
									if(p[offset6] < c_b)
									  goto success_structured;
									else
									  goto homogeneous;
								  else
									if(p[offset6] < c_b)
									  if(p[offset8] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset11] > cb)
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  if(p[offset1] > cb)
									if(p[offset2] > cb)
									  goto success_structured;
									else
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto homogeneous;
								  else
									if(p[offset6] > cb)
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						else
						  if(p[offset11] > cb)
							if(p[offset10] > cb)
							  if(p[offset3] > cb)
								if(p[offset1] > cb)
								  if(p[offset2] > cb)
									goto success_homogeneous;
								  else
									if(p[offset7] > cb)
									  if(p[offset8] > cb)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset6] > cb)
									if(p[offset7] > cb)
									  if(p[offset8] > cb)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset8] > cb)
								  if(p[offset1] > cb)
									if(p[offset2] > cb)
									  goto success_homogeneous;
									else
									  if(p[offset7] > cb)
										goto success_homogeneous;
									  else
										goto homogeneous;
								  else
									if(p[offset6] > cb)
									  if(p[offset7] > cb)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
					  else
						if(p[offset9] < c_b)
						  if(p[offset2] > cb)
							if(p[offset1] > cb)
							  if(p[offset4] > cb)
								if(p[offset10] > cb)
								  if(p[offset3] > cb)
									if(p[offset11] > cb)
									  goto success_structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										if(p[offset11] < c_b)
										  if(p[offset10] < c_b)
											goto success_structured;
										  else
											goto structured;
										else
										  goto structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset6] < c_b)
								  if(p[offset7] < c_b)
									if(p[offset8] < c_b)
									  if(p[offset10] < c_b)
										if(p[offset4] < c_b)
										  goto success_structured;
										else
										  if(p[offset11] < c_b)
											goto success_structured;
										  else
											goto structured;
									  else
										if(p[offset3] < c_b)
										  if(p[offset4] < c_b)
											goto success_structured;
										  else
											goto structured;
										else
										  goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset6] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset8] < c_b)
									if(p[offset4] < c_b)
									  if(p[offset3] < c_b)
										goto success_structured;
									  else
										if(p[offset10] < c_b)
										  goto success_structured;
										else
										  goto homogeneous;
									else
									  if(p[offset10] < c_b)
										if(p[offset11] < c_b)
										  goto success_structured;
										else
										  goto homogeneous;
									  else
										goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset6] < c_b)
							  if(p[offset7] < c_b)
								if(p[offset8] < c_b)
								  if(p[offset4] < c_b)
									if(p[offset3] < c_b)
									  goto success_homogeneous;
									else
									  if(p[offset10] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset2] < c_b)
									if(p[offset1] < c_b)
									  if(p[offset3] < c_b)
										if(p[offset4] < c_b)
										  goto success_structured;
										else
										  goto homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						else
						  if(p[offset2] > cb)
							if(p[offset1] > cb)
							  if(p[offset3] > cb)
								if(p[offset4] > cb)
								  if(p[offset10] > cb)
									if(p[offset11] > cb)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						  else
							if(p[offset2] < c_b)
							  if(p[offset3] < c_b)
								if(p[offset4] < c_b)
								  if(p[offset7] < c_b)
									if(p[offset1] < c_b)
									  if(p[offset6] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  if(p[offset6] < c_b)
										if(p[offset8] < c_b)
										  goto success_homogeneous;
										else
										  goto homogeneous;
									  else
										goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
					else
					  if(p[offset2] > cb)
						if(p[offset10] > cb)
						  if(p[offset11] > cb)
							if(p[offset9] > cb)
							  if(p[offset1] > cb)
								if(p[offset3] > cb)
								  goto success_homogeneous;
								else
								  if(p[offset8] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset6] > cb)
								  if(p[offset7] > cb)
									if(p[offset8] > cb)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset1] > cb)
								if(p[offset3] > cb)
								  if(p[offset4] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					  else
						if(p[offset9] > cb)
						  if(p[offset7] > cb)
							if(p[offset8] > cb)
							  if(p[offset10] > cb)
								if(p[offset11] > cb)
								  if(p[offset1] > cb)
									goto success_homogeneous;
								  else
									if(p[offset6] > cb)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
				else if(p[offset0] < c_b)
				  if(p[offset2] > cb)
					if(p[offset5] > cb)
					  if(p[offset7] > cb)
						if(p[offset6] > cb)
						  if(p[offset4] > cb)
							if(p[offset3] > cb)
							  if(p[offset1] > cb)
								goto success_homogeneous;
							  else
								if(p[offset8] > cb)
								  goto success_homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset9] > cb)
								if(p[offset8] > cb)
								  if(p[offset10] > cb)
									goto success_structured;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset9] > cb)
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  if(p[offset11] > cb)
									goto success_structured;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						else
						  goto homogeneous;
					  else
						if(p[offset9] < c_b)
						  if(p[offset8] < c_b)
							if(p[offset10] < c_b)
							  if(p[offset11] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset1] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  goto success_structured;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					else
					  if(p[offset9] < c_b)
						if(p[offset7] < c_b)
						  if(p[offset8] < c_b)
							if(p[offset5] < c_b)
							  if(p[offset1] < c_b)
								if(p[offset10] < c_b)
								  if(p[offset11] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset3] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset6] < c_b)
								  if(p[offset4] < c_b)
									if(p[offset3] < c_b)
									  goto success_structured;
									else
									  if(p[offset10] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset10] < c_b)
								if(p[offset11] < c_b)
								  if(p[offset1] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset6] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					  else
						goto homogeneous;
				  else
					if(p[offset2] < c_b)
					  if(p[offset9] > cb)
						if(p[offset5] > cb)
						  if(p[offset1] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset10] < c_b)
								if(p[offset3] < c_b)
								  if(p[offset11] < c_b)
									goto success_structured;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								if(p[offset6] > cb)
								  if(p[offset7] > cb)
									if(p[offset8] > cb)
									  if(p[offset11] > cb)
										if(p[offset10] > cb)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset6] > cb)
								if(p[offset7] > cb)
								  if(p[offset8] > cb)
									if(p[offset10] > cb)
									  if(p[offset4] > cb)
										goto success_structured;
									  else
										if(p[offset11] > cb)
										  goto success_structured;
										else
										  goto structured;
									else
									  if(p[offset3] > cb)
										if(p[offset4] > cb)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset6] > cb)
							  if(p[offset7] > cb)
								if(p[offset8] > cb)
								  if(p[offset4] > cb)
									if(p[offset3] > cb)
									  goto success_structured;
									else
									  if(p[offset10] > cb)
										goto success_structured;
									  else
										goto homogeneous;
								  else
									if(p[offset10] > cb)
									  if(p[offset11] > cb)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						else
						  if(p[offset3] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset5] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset6] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset11] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset1] < c_b)
								  if(p[offset10] < c_b)
									if(p[offset11] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
					  else
						if(p[offset9] < c_b)
						  if(p[offset5] < c_b)
							if(p[offset1] < c_b)
							  if(p[offset6] < c_b)
								if(p[offset3] < c_b)
								  if(p[offset4] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset8] < c_b)
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										if(p[offset4] < c_b)
										  if(p[offset7] < c_b)
											goto success_structured;
										  else
											goto structured;
										else
										  goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset11] < c_b)
								  if(p[offset3] < c_b)
									if(p[offset4] < c_b)
									  goto success_homogeneous;
									else
									  if(p[offset10] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
								  else
									if(p[offset8] < c_b)
									  if(p[offset10] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset6] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset8] < c_b)
									if(p[offset4] < c_b)
									  if(p[offset3] < c_b)
										goto success_structured;
									  else
										if(p[offset10] < c_b)
										  goto success_structured;
										else
										  goto homogeneous;
									else
									  if(p[offset10] < c_b)
										if(p[offset11] < c_b)
										  goto success_structured;
										else
										  goto homogeneous;
									  else
										goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset10] < c_b)
							  if(p[offset11] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset3] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset8] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						else
						  if(p[offset3] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset5] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset6] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset11] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset1] < c_b)
								  if(p[offset10] < c_b)
									if(p[offset11] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
					else
					  if(p[offset9] < c_b)
						if(p[offset7] < c_b)
						  if(p[offset8] < c_b)
							if(p[offset5] < c_b)
							  if(p[offset1] < c_b)
								if(p[offset10] < c_b)
								  if(p[offset11] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset6] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset3] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset6] < c_b)
								  if(p[offset4] < c_b)
									if(p[offset3] < c_b)
									  goto success_homogeneous;
									else
									  if(p[offset10] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset10] < c_b)
								if(p[offset11] < c_b)
								  if(p[offset1] < c_b)
									goto success_homogeneous;
								  else
									if(p[offset6] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					  else
						if(p[offset5] > cb)
						  if(p[offset9] > cb)
							if(p[offset6] > cb)
							  if(p[offset7] > cb)
								if(p[offset8] > cb)
								  if(p[offset4] > cb)
									if(p[offset3] > cb)
									  goto success_homogeneous;
									else
									  if(p[offset10] > cb)
										goto success_homogeneous;
									  else
										goto homogeneous;
								  else
									if(p[offset10] > cb)
									  if(p[offset11] > cb)
										goto success_homogeneous;
									  else
										goto homogeneous;
									else
									  goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
				else
				  if(p[offset5] > cb)
					if(p[offset9] > cb)
					  if(p[offset6] > cb)
						if(p[offset7] > cb)
						  if(p[offset4] > cb)
							if(p[offset3] > cb)
							  if(p[offset8] > cb)
								goto success_homogeneous;
							  else
								if(p[offset1] > cb)
								  if(p[offset2] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  goto success_homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							if(p[offset11] > cb)
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  goto success_homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						else
						  goto homogeneous;
					  else
						goto homogeneous;
					else
					  if(p[offset2] > cb)
						if(p[offset3] > cb)
						  if(p[offset4] > cb)
							if(p[offset7] > cb)
							  if(p[offset1] > cb)
								if(p[offset6] > cb)
								  goto success_homogeneous;
								else
								  goto homogeneous;
							  else
								if(p[offset6] > cb)
								  if(p[offset8] > cb)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					  else
						goto homogeneous;
				  else
					if(p[offset5] < c_b)
					  if(p[offset9] < c_b)
						if(p[offset6] < c_b)
						  if(p[offset7] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset3] < c_b)
								if(p[offset8] < c_b)
								  goto success_homogeneous;
								else
								  if(p[offset1] < c_b)
									if(p[offset2] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								if(p[offset8] < c_b)
								  if(p[offset10] < c_b)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							else
							  if(p[offset11] < c_b)
								if(p[offset8] < c_b)
								  if(p[offset10] < c_b)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  goto homogeneous;
							  else
								goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					  else
						if(p[offset2] < c_b)
						  if(p[offset3] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset7] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset6] < c_b)
									goto success_homogeneous;
								  else
									goto homogeneous;
								else
								  if(p[offset6] < c_b)
									if(p[offset8] < c_b)
									  goto success_homogeneous;
									else
									  goto homogeneous;
								  else
									goto homogeneous;
							  else
								goto homogeneous;
							else
							  goto homogeneous;
						  else
							goto homogeneous;
						else
						  goto homogeneous;
					else
					  goto homogeneous;
			}
}
structured:
{
			x++;			
			if(x>xsizeB)	
				break;
			else
			{
				register const unsigned char* const p = im + y*width + x;
				register const int cb = *p + b;
				register const int c_b = *p - b;
				if(p[offset0] > cb)
				  if(p[offset5] > cb)
					if(p[offset2] > cb)
					  if(p[offset9] > cb)
						if(p[offset1] > cb)
						  if(p[offset6] > cb)
							if(p[offset3] > cb)
							  if(p[offset4] > cb)
								goto success_structured;
							  else
								if(p[offset10] > cb)
								  if(p[offset11] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  if(p[offset11] > cb)
									goto success_structured;
								  else
									if(p[offset4] > cb)
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset11] > cb)
							  if(p[offset3] > cb)
								if(p[offset4] > cb)
								  goto success_structured;
								else
								  if(p[offset10] > cb)
									goto success_structured;
								  else
									goto structured;
							  else
								if(p[offset8] > cb)
								  if(p[offset10] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  goto structured;
						else
						  if(p[offset6] > cb)
							if(p[offset7] > cb)
							  if(p[offset8] > cb)
								if(p[offset4] > cb)
								  if(p[offset3] > cb)
									goto success_structured;
								  else
									if(p[offset10] > cb)
									  goto success_structured;
									else
									  goto structured;
								else
								  if(p[offset10] > cb)
									if(p[offset11] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								goto structured;
							else
							  goto structured;
						  else
							goto structured;
					  else
						if(p[offset3] > cb)
						  if(p[offset4] > cb)
							if(p[offset1] > cb)
							  if(p[offset6] > cb)
								goto success_structured;
							  else
								if(p[offset11] > cb)
								  goto success_structured;
								else
								  goto structured;
							else
							  if(p[offset6] > cb)
								if(p[offset7] > cb)
								  if(p[offset8] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							goto structured;
						else
						  goto structured;
					else
					  if(p[offset9] > cb)
						if(p[offset7] > cb)
						  if(p[offset8] > cb)
							if(p[offset1] > cb)
							  if(p[offset10] > cb)
								if(p[offset11] > cb)
								  goto success_structured;
								else
								  if(p[offset6] > cb)
									if(p[offset4] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset6] > cb)
								  if(p[offset3] > cb)
									if(p[offset4] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset6] > cb)
								if(p[offset4] > cb)
								  if(p[offset3] > cb)
									goto success_structured;
								  else
									if(p[offset10] > cb)
									  goto success_structured;
									else
									  goto structured;
								else
								  if(p[offset10] > cb)
									if(p[offset11] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								goto structured;
						  else
							goto structured;
						else
						  goto structured;
					  else
						goto structured;
				  else
					if(p[offset5] < c_b)
					  if(p[offset9] > cb)
						if(p[offset3] < c_b)
						  if(p[offset4] < c_b)
							if(p[offset11] > cb)
							  if(p[offset1] > cb)
								if(p[offset8] > cb)
								  if(p[offset10] > cb)
									if(p[offset2] > cb)
									  goto success_structured;
									else
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
								  else
									goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset2] < c_b)
									  if(p[offset7] < c_b)
										if(p[offset8] < c_b)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset6] > cb)
								  if(p[offset7] > cb)
									if(p[offset8] > cb)
									  if(p[offset10] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset2] < c_b)
									  if(p[offset7] < c_b)
										if(p[offset1] < c_b)
										  goto success_structured;
										else
										  if(p[offset8] < c_b)
											goto success_structured;
										  else
											goto structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							else
							  if(p[offset2] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset1] < c_b)
									if(p[offset6] < c_b)
									  goto success_structured;
									else
									  goto structured;
								  else
									if(p[offset6] < c_b)
									  if(p[offset8] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset11] > cb)
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  if(p[offset1] > cb)
									if(p[offset2] > cb)
									  goto success_structured;
									else
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset6] > cb)
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						else
						  if(p[offset11] > cb)
							if(p[offset10] > cb)
							  if(p[offset3] > cb)
								if(p[offset1] > cb)
								  if(p[offset2] > cb)
									goto success_structured;
								  else
									if(p[offset7] > cb)
									  if(p[offset8] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  if(p[offset6] > cb)
									if(p[offset7] > cb)
									  if(p[offset8] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset8] > cb)
								  if(p[offset1] > cb)
									if(p[offset2] > cb)
									  goto success_structured;
									else
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset6] > cb)
									  if(p[offset7] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							else
							  goto structured;
						  else
							goto structured;
					  else
						if(p[offset9] < c_b)
						  if(p[offset2] > cb)
							if(p[offset1] > cb)
							  if(p[offset4] > cb)
								if(p[offset10] > cb)
								  if(p[offset3] > cb)
									if(p[offset11] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										if(p[offset11] < c_b)
										  if(p[offset10] < c_b)
											goto success_structured;
										  else
											goto structured;
										else
										  goto structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset6] < c_b)
								  if(p[offset7] < c_b)
									if(p[offset8] < c_b)
									  if(p[offset10] < c_b)
										if(p[offset4] < c_b)
										  goto success_structured;
										else
										  if(p[offset11] < c_b)
											goto success_structured;
										  else
											goto structured;
									  else
										if(p[offset3] < c_b)
										  if(p[offset4] < c_b)
											goto success_structured;
										  else
											goto structured;
										else
										  goto structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset6] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset8] < c_b)
									if(p[offset4] < c_b)
									  if(p[offset3] < c_b)
										goto success_structured;
									  else
										if(p[offset10] < c_b)
										  goto success_structured;
										else
										  goto structured;
									else
									  if(p[offset10] < c_b)
										if(p[offset11] < c_b)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset6] < c_b)
							  if(p[offset7] < c_b)
								if(p[offset8] < c_b)
								  if(p[offset4] < c_b)
									if(p[offset3] < c_b)
									  goto success_structured;
									else
									  if(p[offset10] < c_b)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  if(p[offset2] < c_b)
									if(p[offset1] < c_b)
									  if(p[offset3] < c_b)
										if(p[offset4] < c_b)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								goto structured;
							else
							  goto structured;
						else
						  if(p[offset2] > cb)
							if(p[offset1] > cb)
							  if(p[offset3] > cb)
								if(p[offset4] > cb)
								  if(p[offset10] > cb)
									if(p[offset11] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						  else
							if(p[offset2] < c_b)
							  if(p[offset3] < c_b)
								if(p[offset4] < c_b)
								  if(p[offset7] < c_b)
									if(p[offset1] < c_b)
									  if(p[offset6] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  if(p[offset6] < c_b)
										if(p[offset8] < c_b)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto homogeneous;
					else
					  if(p[offset2] > cb)
						if(p[offset10] > cb)
						  if(p[offset11] > cb)
							if(p[offset9] > cb)
							  if(p[offset1] > cb)
								if(p[offset3] > cb)
								  goto success_structured;
								else
								  if(p[offset8] > cb)
									goto success_structured;
								  else
									goto structured;
							  else
								if(p[offset6] > cb)
								  if(p[offset7] > cb)
									if(p[offset8] > cb)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset1] > cb)
								if(p[offset3] > cb)
								  if(p[offset4] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							goto structured;
						else
						  goto structured;
					  else
						if(p[offset9] > cb)
						  if(p[offset7] > cb)
							if(p[offset8] > cb)
							  if(p[offset10] > cb)
								if(p[offset11] > cb)
								  if(p[offset1] > cb)
									goto success_structured;
								  else
									if(p[offset6] > cb)
									  goto success_structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						  else
							goto structured;
						else
						  goto structured;
				else if(p[offset0] < c_b)
				  if(p[offset2] > cb)
					if(p[offset5] > cb)
					  if(p[offset7] > cb)
						if(p[offset6] > cb)
						  if(p[offset4] > cb)
							if(p[offset3] > cb)
							  if(p[offset1] > cb)
								goto success_structured;
							  else
								if(p[offset8] > cb)
								  goto success_structured;
								else
								  goto structured;
							else
							  if(p[offset9] > cb)
								if(p[offset8] > cb)
								  if(p[offset10] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset9] > cb)
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  if(p[offset11] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						else
						  goto structured;
					  else
						if(p[offset9] < c_b)
						  if(p[offset8] < c_b)
							if(p[offset10] < c_b)
							  if(p[offset11] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset1] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  goto success_structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						  else
							goto structured;
						else
						  goto structured;
					else
					  if(p[offset9] < c_b)
						if(p[offset7] < c_b)
						  if(p[offset8] < c_b)
							if(p[offset5] < c_b)
							  if(p[offset1] < c_b)
								if(p[offset10] < c_b)
								  if(p[offset11] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset3] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset6] < c_b)
								  if(p[offset4] < c_b)
									if(p[offset3] < c_b)
									  goto success_structured;
									else
									  if(p[offset10] < c_b)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							else
							  if(p[offset10] < c_b)
								if(p[offset11] < c_b)
								  if(p[offset1] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  goto success_structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							goto structured;
						else
						  goto structured;
					  else
						goto structured;
				  else
					if(p[offset2] < c_b)
					  if(p[offset9] > cb)
						if(p[offset5] > cb)
						  if(p[offset1] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset10] < c_b)
								if(p[offset3] < c_b)
								  if(p[offset11] < c_b)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								if(p[offset6] > cb)
								  if(p[offset7] > cb)
									if(p[offset8] > cb)
									  if(p[offset11] > cb)
										if(p[offset10] > cb)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset6] > cb)
								if(p[offset7] > cb)
								  if(p[offset8] > cb)
									if(p[offset10] > cb)
									  if(p[offset4] > cb)
										goto success_structured;
									  else
										if(p[offset11] > cb)
										  goto success_structured;
										else
										  goto structured;
									else
									  if(p[offset3] > cb)
										if(p[offset4] > cb)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset6] > cb)
							  if(p[offset7] > cb)
								if(p[offset8] > cb)
								  if(p[offset4] > cb)
									if(p[offset3] > cb)
									  goto success_structured;
									else
									  if(p[offset10] > cb)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset10] > cb)
									  if(p[offset11] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						else
						  if(p[offset3] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset5] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset6] < c_b)
									goto success_structured;
								  else
									if(p[offset11] < c_b)
									  goto success_structured;
									else
									  goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset1] < c_b)
								  if(p[offset10] < c_b)
									if(p[offset11] < c_b)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  goto structured;
						  else
							goto structured;
					  else
						if(p[offset9] < c_b)
						  if(p[offset5] < c_b)
							if(p[offset1] < c_b)
							  if(p[offset6] < c_b)
								if(p[offset3] < c_b)
								  if(p[offset4] < c_b)
									goto success_structured;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  if(p[offset8] < c_b)
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										if(p[offset4] < c_b)
										  if(p[offset7] < c_b)
											goto success_structured;
										  else
											goto structured;
										else
										  goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset11] < c_b)
								  if(p[offset3] < c_b)
									if(p[offset4] < c_b)
									  goto success_structured;
									else
									  if(p[offset10] < c_b)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset8] < c_b)
									  if(p[offset10] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							else
							  if(p[offset6] < c_b)
								if(p[offset7] < c_b)
								  if(p[offset8] < c_b)
									if(p[offset4] < c_b)
									  if(p[offset3] < c_b)
										goto success_structured;
									  else
										if(p[offset10] < c_b)
										  goto success_structured;
										else
										  goto structured;
									else
									  if(p[offset10] < c_b)
										if(p[offset11] < c_b)
										  goto success_structured;
										else
										  goto structured;
									  else
										goto structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset10] < c_b)
							  if(p[offset11] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset3] < c_b)
									goto success_structured;
								  else
									if(p[offset8] < c_b)
									  goto success_structured;
									else
									  goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								goto structured;
							else
							  goto structured;
						else
						  if(p[offset3] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset5] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset6] < c_b)
									goto success_structured;
								  else
									if(p[offset11] < c_b)
									  goto success_structured;
									else
									  goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset7] < c_b)
									  if(p[offset8] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset1] < c_b)
								  if(p[offset10] < c_b)
									if(p[offset11] < c_b)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  goto structured;
						  else
							goto structured;
					else
					  if(p[offset9] < c_b)
						if(p[offset7] < c_b)
						  if(p[offset8] < c_b)
							if(p[offset5] < c_b)
							  if(p[offset1] < c_b)
								if(p[offset10] < c_b)
								  if(p[offset11] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset3] < c_b)
									  if(p[offset4] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset6] < c_b)
								  if(p[offset4] < c_b)
									if(p[offset3] < c_b)
									  goto success_structured;
									else
									  if(p[offset10] < c_b)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset10] < c_b)
									  if(p[offset11] < c_b)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							else
							  if(p[offset10] < c_b)
								if(p[offset11] < c_b)
								  if(p[offset1] < c_b)
									goto success_structured;
								  else
									if(p[offset6] < c_b)
									  goto success_structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							goto structured;
						else
						  goto structured;
					  else
						if(p[offset5] > cb)
						  if(p[offset9] > cb)
							if(p[offset6] > cb)
							  if(p[offset7] > cb)
								if(p[offset8] > cb)
								  if(p[offset4] > cb)
									if(p[offset3] > cb)
									  goto success_structured;
									else
									  if(p[offset10] > cb)
										goto success_structured;
									  else
										goto structured;
								  else
									if(p[offset10] > cb)
									  if(p[offset11] > cb)
										goto success_structured;
									  else
										goto structured;
									else
									  goto structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						  else
							goto homogeneous;
						else
						  goto structured;
				else
				  if(p[offset5] > cb)
					if(p[offset9] > cb)
					  if(p[offset6] > cb)
						if(p[offset7] > cb)
						  if(p[offset4] > cb)
							if(p[offset3] > cb)
							  if(p[offset8] > cb)
								goto success_structured;
							  else
								if(p[offset1] > cb)
								  if(p[offset2] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  goto success_structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							if(p[offset11] > cb)
							  if(p[offset8] > cb)
								if(p[offset10] > cb)
								  goto success_structured;
								else
								  goto structured;
							  else
								goto structured;
							else
							  goto structured;
						else
						  goto structured;
					  else
						goto structured;
					else
					  if(p[offset2] > cb)
						if(p[offset3] > cb)
						  if(p[offset4] > cb)
							if(p[offset7] > cb)
							  if(p[offset1] > cb)
								if(p[offset6] > cb)
								  goto success_structured;
								else
								  goto structured;
							  else
								if(p[offset6] > cb)
								  if(p[offset8] > cb)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  goto structured;
						  else
							goto structured;
						else
						  goto structured;
					  else
						goto structured;
				  else
					if(p[offset5] < c_b)
					  if(p[offset9] < c_b)
						if(p[offset6] < c_b)
						  if(p[offset7] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset3] < c_b)
								if(p[offset8] < c_b)
								  goto success_structured;
								else
								  if(p[offset1] < c_b)
									if(p[offset2] < c_b)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								if(p[offset8] < c_b)
								  if(p[offset10] < c_b)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							else
							  if(p[offset11] < c_b)
								if(p[offset8] < c_b)
								  if(p[offset10] < c_b)
									goto success_structured;
								  else
									goto structured;
								else
								  goto structured;
							  else
								goto structured;
						  else
							goto structured;
						else
						  goto structured;
					  else
						if(p[offset2] < c_b)
						  if(p[offset3] < c_b)
							if(p[offset4] < c_b)
							  if(p[offset7] < c_b)
								if(p[offset1] < c_b)
								  if(p[offset6] < c_b)
									goto success_structured;
								  else
									goto structured;
								else
								  if(p[offset6] < c_b)
									if(p[offset8] < c_b)
									  goto success_structured;
									else
									  goto structured;
								  else
									goto structured;
							  else
								goto structured;
							else
							  goto structured;
						  else
							goto structured;
						else
						  goto structured;
					else
					  goto homogeneous;
			}
}
success_homogeneous:
			if(total == nExpectedCorners)
			{
				if(nExpectedCorners==0)
				{
					nExpectedCorners=512;
					corners_all.reserve(nExpectedCorners);
				}
				else
				{
					nExpectedCorners *=2;
					corners_all.reserve(nExpectedCorners);
				}
			}
			h.x=x;
			h.y=y;
			corners_all.push_back(h);
			total++;
			goto homogeneous;				
success_structured:
			if(total == nExpectedCorners)
			{
				if(nExpectedCorners==0)
				{
					nExpectedCorners=512;
					corners_all.reserve(nExpectedCorners);
				}
				else
				{
					nExpectedCorners *=2;
					corners_all.reserve(nExpectedCorners);
				}
			}
			h.x=x;
			h.y=y;
			corners_all.push_back(h);
			total++;						
			goto structured;				
		}									
	}										
}

//end of file
